

# NORDIC-1M Design Specification

by Vlad Bril, Robin Han, Sasha Eglit, Rakesh Bindlish, Dwarka Partani.

Jeff Ort

rev.3.9 October 10, 1993

## 1.0 Introduction & Table of Contents

Nordic is Cirrus Logic's Fourth Generation Flat Panel VGA Controller to be marketed in first half of 1994.

Nordic-1M is a mid-end member of the Nordic family. It is a GUI Accelerator with PCI support and Multi-Media Features.

Nordic-1M is targeted for the mid to high end of the Note-book Computer Market and for the energy efficient desk-top computers mother-boards.

Nordic-1M is not targeted to the adapter market.

### 1.1 Table of Contents

This Specification will address the following:

1. Introduction and Table of Contents
2. Basic Feature Set
3. Detailed List of Features
4. Pinout and Pin Description
5. Architecture Specification
6. Register Specification
7. Product Implementation Plan

Cirrus Confidential  
Business Information

CL 146366

## 2.0 Nordic-1M Basic Feature Set

1. Flat Panel VGA Compatible GUI Accelerator register and feature compatible to 5428 and Alpine I A/V. Priority: A (= highest).
2. 32bit CPU, 32bit Video Memory, 32bit BLT and 32bit CPU to Video Memory Data Path. Priority: A (= highest).
3. 208 pin QFP package.
4. Targeted to sample CY Q1'94, production CY Q2 '94. Priority: A (= highest).
5. Target cost: \$12 to \$10 -> less than 400mil [/] in C8 Foster City.

### 6. Multimedia Features

- Part of a well defined System Solution for high performance CD-ROM video and audio playback for the portable market. Priority: B
- Part of a well defined System Solution for mid performance low cost live NTSC Video and Audio with the NTSC decoder on a PCMCIA card. Priority: B
- Audio Port to Display Memory: Audio Buffer to Serial Interface for CS4248 Audio Codec. Priority: C (CS4215 is not fit for notebook computers).
- Video Playback decompression acceleration for CinePak including Color Space Conversion (YUV -> RGB). Priority: B
- Live Video in a 320x240 or 640x480 Window from a proprietaryly compressed TV decoded data source (at 30Hz) on TFT color panels. Data is stored compressed and it is decompressed to 18bit/pel or 24bit/pel in real time at display time. NTSC decoder and data compressor is on the PCMCIA card or the PCMCIA controller. Please note that due to live video bandwidth requirements on PCMCIA bus, a relatively non-expensive way to achieve the second feature is to implement this compression algorithm. Priority: B
- Color Key Live Video Overlay based on a 5428-like Feature Connector with PCI bus (only).

### 7. Integrated in Nordic 1-M

- Color Space Converter for CinePak. Priority: B
- 18bit DAC with direct color capability Priority: A
- 24bit RAMDAC with true color capability Priority: C
- Clock Synthesizers for Video and Memory Clock (65MHz/3V, 110MHz/4.5V). Priority: A

Cirrus Confidential  
Business Information

CL 146367

Cirrus Logic, Inc. Confidential Information

- DAC IRef Current Source on chip. Priority: C. *Boyd and ManShek are working on it.*

8. Direct Bus Interface:

- 32bit VESA-VL bus (and 486 local bus) Priority: A
- 32bit PCI bus. No on chip BIOS ROM support in PCI. Priority: A
- 16bit ISA bus for demonstration and easy system validation. Priority: B
- 32K or 48KB BIOS ROM support in ISA and VESA VL bus. Priority: B (only for BIOS/ system debug)
- At least 5 scratch pad registers: optimum 8 scratch pad registers. Priority: A.

9. Performance Enhancements to achieve 15-20MWinmarks at 1Kx768 8b/pel:

- 32bit BitBLT with memory mapped I/O BitBLT registers (as in 5428 ?or Alpine) Priority: A
- BLT buffer of 8 (or 16) bytes for Source (and Destination ?) data, (5428 buffer is 8bytes. Alpine is 16bytes) (as 5428)
- X/Y offset for Pattern BLT (as in Alpine) Priority: C
- h/w graphic cursor 64x64 (as in 5428)
- color expansion (as in 5428)
- linear memory addressing (as in 5428)
- 4 stage 32bit wide write buffer and capability to page CPU cycles if accumulated in the write buffer (this is already in 5428)

10. Display Memory:

- 0.5MB (16bit wide), 1MB or 2MB memory addressing 32bit wide (as in 5428)
- 1 or 2 256Kx16 one bank or 4 256Kx16 two banks (2 CAS symmetric, 2 WE asymmetric) (as in 5428)
- maximum memory clock frequency: 50MHz/3V, 65MHz/4.5V Priority: C

11. Flat Panel Support: [Priority: A]

- Color TFT (24bit, 18bit, 12bit, 9bit)
- Color Dual Scan and Single Scan STN (16 and 8 bit, including dual clock panels)
- Monochrome TFT (8bit),
- Monochrome Dual Scan STN (8bit),
- Monochrome Single Scan (4 and 8bit) support

Cirrus Confidential  
Business Information

CL 146368

**Cirrus Logic, Inc. Confidential Information**

- Simulscan with all Fast Panels (6.3MHz or equivalent) with 32bit wide memory.  
No simulscan with 16bit wide memory with dual scan color panels.  
No simulscan for 3MHz monochrome dual scan panels.
- 640x480 single and dual scan support (Priority: A)
- 800x600 TFT and no single and dual mono and color STN panel support (Priority: C)
- 1024x768 TFT and no single and dual scan STN panel support . (Priority: D)

**12. Display Features**

- High quality monochrome and color shading, at least as good as 6440. Priority: A
- Shading option for fast panels. Priority: B
- Up to 8, 64x64 Hardware Icons independently mapped color+transparent background. Priority: C
- *Whisper Cross-Talk Reduction (If panels will be available in the time frame and if we can accomodate it with the shading algorithm). Priority: C*
- *"Office Productivity Booster Dual Display" 640x480 (panel) & 640x480 (CRT) 4 or 8b/pel or 640x480 (panel) & 1024x768 (CRT) 4 or 8b/pel Priority: E*
- Vertical Expansion in text and graphics (as in 6235 or 6440)
- Automatic Centering if not expanded (as in 6235)
- *Grey-Shades Maping options ?? Is this needed ? Priority: D*
- Text Contrast Enhancement options. (as in 6235 or 6440)
- *Inking Plane ?? Priority: D*
- *180 and 90 degree image rotation ?? Priority: D*
- *12 and 16dots wide font support ?? Priority: D*
- *h/w offset on h/w cursor ?? Priority: D*

**13. Resolutions Supported:**

- the same as 5428 at 5V (4.5Vmin)
- up-to 45MHz dotclk (1024x768, 60Hz interlaced) at 3.3V

**14. Power Management**

- Mixed 3.3V and 5V operation: memory, host and flat panel independent VDD
- Green-PC spec support. Priority: B
- Stand-by Mode with internal stand-by timer (as in 6235)

**Cirrus Confidential  
Business Information**

**CL 146369**

- Suspend Mode I/O or pin in all modes (LCD, CRT, Simulscan)
- *Light Sleep ?? - better not for this chip as it requires too much h/w. Priority: F*
- Panel Power Sequencing: automatic or under I/O control (as in 6235)
- Reduced Active Power in Panel Only Operation: < 60mAmp @3.3V. Priority: A
- Reduced Suspend Current: < 0.5mAmp. Priority: A

## 2.1 Inputs from the Nordic-1M Features Meeting of 09/10/93

- 24bit DAC if not too expensive (VAR)
- mclk @5V max 65MHz, @3V max 50MHz
- vclk and fpvdclk @5V max 85MHz, @3V max 65MHz
- panels:
  - TFT 1280x1024? ##, 1kx768 ##, 800x600 ##, 640x480  
24bit, 18bit, 12bit, 9bit color, 6bit mono  
NEC analog output? ##
  - STN 800x600 dual scan color, 640x480 ds color 16bit  
640x480 ss color 8bit  
640x480 mono bit 8bit and 4bit
  - horiz ## and vertical centering
  - normal 9dot font in 800x600 text ##
  - simulscan for 800x600 and 1kx768 panels ## (need to run all modes at 800x600 or 1024x768 resolutions -> option to clock panel till h&v Blank)
  - support for two alternate fonts 10x24 for 800x600 (10x18 actual with spacing) and 12x25 for 1kx768 ## difficult !!
  - h&v text expansion in 800x600 and 1kx768 panels ## ?
  - color text enhancement ## : bright white instead of white
  - on chip cross-talk reduction ## ? - any improvement ?
  - shading look-up tables ## ? - only if not too large
- NO Whisper support even on the bus side - out !
- NO one 256Kx16 DRAM support - out !
- h/w icon support: with h/w cursor, up to 4 simultaneously. Horizontal position controlled in increments of 64 pixels.  
Icon attributes: off/on, 4 colors/3colors + transparent, no\_blink/blink, (simple/double).  
H/W cursor goes over the h/w icon (visually). Uses independently mapped color in RAMDAC RAM. Start at scan-line 64.
- PC98 integration? ## - to be negotiated
- reserve pins for SDRAM-s and CDRAM-s ##
- NO true dual display!

Cirrus Confidential  
Business Information

## 2.2 Inputs from Compaq 09/10/93

- 50MHz 486DX bus
- 75Hz refresh rate
- need one 256Kx16 support with Audio and some video for Contura - build one motherboard for Contura and LT Lite. Two DRAM-s only on LT Lite.

CL 146370

**Cirrus Logic, Inc. Confidential Information**

- think that 8KB/buffer of audio buffer is not enough
- want to use Analog Devices for Audio
- No clear winner on compression. They are watching. Need Indeo driver.
- Play-back zoom is required. At least pixel replication.
- Very interested in Compressed Live Video. Want to talk more.
- need h/w icon 64x64 with 3col+transparency or 4 color, with pixel replication to 128x128.

**2.3 Inputs from AST 09/15/93**

- They prefer horizontal icon

**2.4 New Features as of 10/04/93**

- 4bit/pel packed support for Windows Chicago
- 8bit/pel video out to the Feature Connector for conversion to NTSC-out with Nordic running 640x480 interlaced mode.  
Another idea was to use some of the panel outputs in this case and extend the data out to 16bits.
- The h/w icon can be horizontal or vertical using the Motion Video Window as implementation vehicle -> is it worth?
- IBM Raleigh asked for 12 and 16dots wide fonts for h/w assisted Kanji. 10/04/93
- IBM Raleigh asked for 8bit monochrome TFT panel support. 10/04/93

**3.0 Important Additions to 5428 Data Base**

1. 32 bit CPU Data bus in VESA VL bus support
2. PCI bus support
3. Mono and color, STN and TFT Flat Panel support (incl. hfb).
4. Live video in a true color window with Windows running in planar VGA mode, without a video port (using PCMCIA standard bus and Sasha's decompression technique).
5. CINE PAK decompression acceleration
6. Audio Port support for CS4215
7. Power Management: panel power sequencing, stand-by mode, suspend mode
8. Mixed Voltage, 3.3V operation and low active/suspend/standby power
9. h/w icon support, with a h/w cursor support
10. BLT performance improvements: Memory Mapped BLT I/O, patterning, 16 byte Source buffer

**Cirrus Confidential  
Business Information**

11. *[dual display 1024x768 on CRT with 640x480 on LCD, using the same RAMDAC] - if decided to do now*

## 4.0 Detailed List of Features

### 4.1 WAS: On the Cross Talk Reduction Technique -> not in -1M

This part was deleted from Nordic-1M spec starting rev. 3.8 (09/11/93).

### 4.2 Green PC Spec Support (Based on VESA DPMS Proposal 1.0p rev. 0.53p)

This specification refers to CRT Monitor power management. Additionally, Nordic will

TABLE 1. Display Power Management Summary

| State        | H SYNC    | V SYNC    | Video RGB | Compliance | Power Savings | Recovery Time     |
|--------------|-----------|-----------|-----------|------------|---------------|-------------------|
| CRT On       | Pulses    | Pulses    | Active    | Mandatory  | None          | NA                |
| CRT Stand-by | No Pulses | Pulses    | Blanked   | Optional   | Minimal       | Short             |
| CRT Sus-pend | Pulses    | No Pulses | Blanked   | Mandatory  | Substantial   | Longer            |
| CRT Off      | No Pulses | No Pulses | Blanked   | Mandatory  | Maximum       | System Dependednt |

control DAC power consumption. These power management CRT Monitor states are not necessarily related to the graphics controller power management states.

We'll define 2 bits - GRE[2:1] (the same as Alpine) that control H SYNC, V SYNC and DAC Power Off signal (or Blank to the DAC).

Cirrus Confidential  
Business Information

CL 146372

TABLE 2. GRE[2:1] Effect

| GRE[2:1] | CRT State | Vsync                            | Hsync                            | DAC Power | Nordic Power Management State |
|----------|-----------|----------------------------------|----------------------------------|-----------|-------------------------------|
| 0        | On        | pulsing                          | pulsing                          | on        | active                        |
| 1        | Stand-by  | pulsing                          | static at MISC[6] inactive level | off       | active                        |
| 2        | Suspend   | static at MISC[7] inactive level | pulsing                          | off       | active or stand-by            |
| 3        | Off       | static at MISC[7] inactive level | static at MISC[6] inactive level | off       | active, stand-by or suspend   |

If Nordic is in its own Suspend mode, the BIOS should program GRE[2:1]=3 to put the monitor (if any) in the Off state.

If Nordic is in its own Stand-by mode, CRT Suspend mode should be forced by the h/w, as stand-by is a timer driven mode and no s/w gets to play.

If Nordic is in LCD only, the BIOS should set GRE[2:1] to 3 to power off the CRT that may be connected to the notebook computer.

If CRT only mode and CRT is in stand-by or suspend, the BIOS may reduce the video clock and even memory clock frequencies after saving the current values.

Except for the above restrictions, CRT Power Management modes are not related to Nordic power management modes: they can be independently programmed.

If MISC bit is programmed for positive polarity, the SYNC signal will be stopped L, otherwise it will be stopped H.

#### 4.3 Play-back Decompression Accelleration (applicable to Cinepak as well as other compression standards) - old, kept here only for reference

##### 4.3.0 The problem

Cirrus Confidential  
Business Information

Cirrus Logic, Inc. Confidential Information

a) When playback data is compressed on a CD ROM, it is encoded in 24bit/pel YUV with chrominance sub-sampling. Due to CDROM reduced bandwidth the display window is 160x120 or 320x240. If this compressed data is decompressed at full pixel depth, it should be displayed as 24bit/pel RGB window under MS Windows. As the play-back data is sent to the graphics controller from the CPU bus, it has to be placed in Video Memory in 320KB.

A standard VGA controller or even GD5428 are able to display the 24bit/pel play-back window only if MS Windows is run in 24bit/pel mode (for instance 1024x768 24bit/pel or 640x480 24bit/pel) by the driver. Under these conditions, the CPU will have to write the un-compressed 24bit/pel play-back data in the appropriate position in Video Memory, contiguous to the entire displayed data.

So, in order to display 24bit/pel in a play-back window, GD5428 needs the driver to run 24bit/pel at the maximum display resolution.

But, in order to run 640x480 at 24bit/pel we need 921.6KB of Video Memory and in order to run 1024x768 24bit/pel we need 2359.296KB of video memory. (Please note that 2M of memory has 2097.152KB).

Also, when running windows in 24bit/pel mode the performance will decrease 3 or 4 times relative to 8bit/pel mode, especially when using DRAM as Video Memory.

b) When running through MS Windows GDI, the driver can play-back data at 15fps or less (with a 486 33MHz). It is desirable to play-back data at 30fps.

This can be accomplished today only if the driver does not go through GDI.

c) If a picture was stored on CDROM at low resolution (160x120 or 320x240) and it needs to be "zoomed", it has to be interpolated both horizontally and vertically for good picture quality. Vertical interpolation is expensive in h/w.

Cirrus Confidential  
Business Information

#### 4.3.1 The Generic Solution - old, here for reference only

Today's Windows Accelerators run MS Windows, including the play-back window with the same pixel depth (8bit/pel), normally going through the RAMDAC, but using a split palette approach with 16 colors reserved for MS Windows and 240 colors reserved for the play-back window. The Cinepak driver writes data in video memory in 3:3:2 RGB format

(8bits/pel) which is created by the driver. Because of the s/w overhead involved in decompression as well as the GDI overhead, it is hard to go beyond 320x240 clips at 15fps, though the display quality is much lower than what Cinepak could achieve (240 colors versus 16 million colors).

To run Cinepak with 24bit/pel resolution, today's graphics controllers would require to run MS Windows in 24bit/pel mode, requiring almost 1MB in 640x480 and over 2MB-s in 1024x768 modes.

**Cirrus Logic, Inc. Confidential Information**

A graphics controller that could run MS Windows in 8 or 16bit/pel mode while displaying only the play-back window in 24bit/pel mode would increase significantly picture quality without degrading too much MS Windows performance with play-back. would reduce significantly the amount of Video Memory required for the same picture quality and would allow a higher frame rate for the play-back.

Further, if the play-back data is stored in Video Memory in a semi-compressed format that requires less than 24bit/pel this would further decrease the Video Memory requirements and it may even reduce the video memory band-width requirements.

When zooming the play-back window from 160x120 to 320x240 or higher it is important to interpolate. Vertical interpolation can be done in s/w but with a relatively large overhead. It may be possible to do vertical interpolation on key frames, but there is no practical way of doing vertical interpolation on inter-frames either in s/w or with h/w assist on the CPU write side of the graphics controller. If s/w driven vertical interpolation on key frames is not a solution, then vertical interpolation can be only achieved in h/w on the CRT read side and this requires either one or two 16bit/pel line buffers or a big penalty on video memory bandwidth (the equivalent of reading 32 or 48bits/pel).

Horizontal interpolation can be done before play-back data is displayed, without s/w help.

Please note that there are multiple ways to solve the play-back problems. In Nordic-1M we'll try to strike a balance between the complexity of the h/w solution and the quality of the play-back image.

To a large extent, the solution adopted in Nordic-1M will be generic, not tied to Cinepak, though it will be first applied to Cinepak.

#### 4.3.2 Nordic-1M old Play-back Acceleration Solution -> canned, kept here for reference

a) Nordic-1M will run Cinepak at 1:1 scale exactly the same way as today's graphics controllers: in 8bit/pel MS Windows with 8bit/pel (3:3:2 RGB) play-back window.

b) Nordic-1M will run 1:2 scale (zoom) in 8bit/pel 1024x768 MS Windows with 24bit/pel (8:8:8 RGB) pixel depth in the play-back window, horizontally interpolated and vertically doubled. Play-back data will be stored in video memory as 16bit/pel (Y0 U01 Y1 U01).

c) Nordic-1M will run at 1:1 scale in 16bit/pel 1024x768 MS Windows with 24bit/pel pixel depth in the play-back window. Play-back data will be stored in video memory as 16bit/pel (Y0 U01 Y1 U01). This mode is good for programs that store data in 320x240 format.

Because today large play-back windows look bad, while small ones look OK, this solution will improve picture quality to a large extent.

**Cirrus Confidential  
Business Information**

**Concerns:**

Many play-back programs today don't even have a zoom option. To this extent, mode "b" may not be needed.

Mode c could be implemented today with 16bit/pel RGB (555) in s/w and the only improvement we provide is 24bit/pel capability and h/w color conversion (some level of acceleration). So mode "c" may not be needed as a special h/w.

**If this is the case, maybe we do not need to do anything in h/w for Cinepak !**

One idea: should we run 24bit/pel MS windows stored in 4:2:2 (Y0 U01 Y1 U01) format? This will allow us to run 24bit/pel MS Windows and use 16bit/pel memory space with no loss of quality. The windows driver could compress the data and the h/w could decompress it.

## 4.4 Nordic-1M Motion Video Architecture

### 4.4.0 The Problems to Solve & Generic Solutions

Nordic-1M is supposed to support CDROM play-back and live-video under Microsoft's Video for Windows. With all of today's VGA Compatible Graphics Controllers, the play-back picture pixel depth has to be the same as the surrounding MS Windows pixel depth. In other words, we have to run MS Windows in a 24bit/pel mode in order to display 24bit/pel in the play-back window.

The only way we can run today live video is from a Video Port (= Feature Connector). In this case we'll use an overlay or a color key to define the live video window. Due to CDROM player, s/w interface complexity, CPU bus and Video Memory limitations, only small clips at 15fps or less can be playd-back today. So today we need a lot of Video Memory to run small clips in slow motion at low rezolution. Nordic-1M will try to use less Video Memory, increase the clips size, their resolution and speed.

**Nordic-1M is supposed to support:**

- accelerated play-back for all popular CDROM compression standards, especially Cinepak and Indeo
- live video from a PCMCIA card in a system with a standard PCMCIA host adapter, for a "Multimedia-Ready Notebook Computer"
- live video from a Feature Connector, preferably VESA Advanced Feature Connector compatible, for a Multimedia Notebook Computer with direct NTSC input (full motherboard solution).

**What will Nordic-1M bring to the Video plate:**

**Cirrus Confidential  
Business Information**

Cirrus Logic, Inc. Confidential Information

- A. Nordic-1M will break the dependency between the pixel depth of MS Windows and the pixel depth of the live-video / play-back window. By doing so, Nordic-1M will be able to run 24bit/pel LV/PB while running MS Windows in 8bit/pel or 4bit/pel (even planar). This will lead to high quality live-video and play-back, while minimizing Video Memory requirements.
- B. Nordic-1M will further reduce Video Memory requirements as well as Video Memory Bandwidth requirements by storing data in compressed form: 4:2:2 YUV (16bit/pel), 4:1:1 YUV (12bit/pel) or Sashapak YUV (2.6bit/pel)
- C. Nordic-1M will define one architecture and work-frame to run both play-back and live-video in a unitary way for both s/w and h/w.
- D. Nordic-1M will support up to two active LV/PB windows at the same time.
- E. By providing h/w YUV->RGB conversion and 1:2 zoom Nordic-1M will accelerate playback for most standards, but mostly for standards that allow us access to their decompressor like Cinepack (for whose decompressor we have a licence).

Nordic-1M will not provide Cinepak specific acceleration (custom BLT).

On the Live Video from Feature Connector (or Video Port)

Due to pin-out limitations, the VAFC implementation has to be limited to 8 pins of data requiring external muxing of 16bit data to Nordic. Further, the VAFC solution will be restricted to 5428 type support: overlay and color key (no memory video port). The only additions to the 5428 support will be the internal YUV-> RGB converter able to accept sequential 4:2:2 YUV (16bit/pel in average: Y0,U,Y1,V) and display it as a 24bit/pel RGB in the overlay/color-key window. We may also support horizontal 1:2 zoom with averaging. Nordic-1M will be back-wards compatible to 5428 and it will support also 16bit 5-5-5 RGB Sierra and 5-6-5 RGB XGA pixel formats. As in 5428, live video from the Feature Connector can be executed only from mode 5F (640x480 256 colors).

In the following we will refer mostly to the other two modes of operation: play-back and live video from a PCMCIA card, which we'll call compressed live video, because due to PCMCIA bus bandwidth limitations, we assume that video data received by Nordic is compressed with Sashapak (see Sashapak details further in this spec). Please note that due to its huge advantages, it makes sense to use Sashapak as a mother-board solution too. The main reason we continue to support the Feature Connector based live video is the availability of drivers for 5428 which will give Nordic an early start in the live video arena.

Video Memory Band-width Constraints

Please note that, even with a 32bit wide Video Memory, there are severe memory bandwidth limitations when running 16bit/pel and 24bit/pel graphics modes.

Assuming that Nordic-1M does 8 CRT fetches in a row and 1 CPU cycle, for a CRT or TFT panel, here are the minimum frequency requirements for memory clock frequency at different resolutions and pixel depths:

24bit/pel:

$R+7P+R=12m+14m=26m$  with 1 CPU cycle per CRT FIFO fill fetches data for  
32B/3B=10pixels

Cirrus Confidential  
Business Information

Cirrus Logic, Inc. Confidential Information

$R+7P = 6m+14m = 20m$  with no CPU cycle during non-display time

min mclk freq = 65MHz / 50MHz @ 640x480 -> Nordic-1M upper limit at 5V CVDD

= 104MHz / 80MHz @ 800x600 -> too high

= 169MHz / 133MHz @ 1024x768 60Hz -> too high

16bit/pel:

$R+7P+R=12m+14m=26m$  /  $R+7P = 20m$  fetches data for 32B/2B=16pixels

min mclk freq = 40.6MHz / 36MHz @ 640x480 -> OK even at 3V

= 65MHz / 50MHz @ 800x600 -> Nordic-1M upper limit at 5V CVDD

= 105MHz / 83MHz @ 1024x768 60Hz -> too high

12bit/pel:

$R+7P+R=12m+14m=26m$  /  $R+7P=20m$  fetches data for 32B/1.5B=21pixels

min mclk freq = 30.9MHz / 23MHz @ 640x480 -> OK even at 3V

= 49.5MHz / 380MHz @ 800x600 -> OK even at 3V

= 80.4MHz / 64MHz @ 1024x768 60Hz -> too high

8bit/pel:

$R+7P+R=12m+14m=26m$  fetches data for 32B/1B=32pixels

min mclk freq = 20.3MHz @ 640x480 -> OK even at 3V

= 40.6MHz @ 800x600 -> OK even at 3V

= 52.8MHz @ 1024x768 60Hz -> OK at 5V

We may conclude that Nordic-1M will be able to run 24bit/pel only at 640x480 rezolution, 16bit/pel up to 800x600, 12bit/pel up to 800x600 and 8bit/pel up to 1024x768 rezolution. These results apply only to CRT or TFT and single scan STN panels.

Please note that for dual scan STN panels the memory requirements increase significantly.

These severe memory bandwidth limitations lead us to attempt to minimize video memory traffic. If we store Cinepak data in 4:2:2, with an avarage of 16bit/pel, independent of Cinepak window size, Nordic-1M will not be able to run Cinepak above 800x600.

Any attempt to execute vertical zoom with interpolation, even with two points interpolation will further aggravate this memory band-width bottleneck. The next step should be 100MHz SDRAM-s with a large CRT FIFO (32x32) or 64bit wide memory data bus.

These considerations apply to any playback compression standard that stores data in video-memory as 16bit/pel in avarage. The key to a successful compression standard would be one that does decompresssion on the CRT memory read and stores data in memory as 8bit/pel or less, in avarage.

As we store live video at 2.6bit/pel and fetch it as if it was 8bit/pel with Sashapak. Nordic-1M should be able to run live video even at 1024x768.

If we defined a new CDROM play-back standard based on Sashapak, then we could run even 1024x768 with 24bit/pel accuracy and keep it memory as an 8bit/pel. Keith and Ken are actually working on it, with Sasha's help.

Cirrus Confidential  
Business Information

#### 4.4.1 On Sashapak

Sashapak is a highly assymetric, lossy "Block Truncation" compression algorithm optimized for visually equivalent image processing.

Data is proccesed as Y.U.V one byte each. U and V are sub-sampled, characterizing one 8

Cirrus Logic, Inc. Confidential Information

by 8 pixel array, while Y is characterizing a 4x4 pixel array. Actually one of two values is assigned to each pixel inside the 4x4 (for Y) and 8x8 (for U and V).

At compression time, the compression chip determines a threshold and two values U&L for each group of sixteen (4x4) pixels. This way all pixels above threshold will be assigned the value U, all pixels below threshold will be assigned the value L.



At decompression, the bitmap will control a mux between the U and L values. This way the decompression is straightforward.

The main drawback of this approach is that a BITMAP contains Y data from 4 scan lines and U,V data from 8 scan lines. When data is read from memory to be displayed only data from one scan line is used. Similarly the U/L values apply to several scan-lines and the same value will be read in each scan line. The same data will be read again and again in each scan line raising the actual memory bandwidth requirements to an equivalent of 16bit/pel map.

In order to overcome this problem and reduce memory bandwidth requirements, Sasha proposed a scan line oriented, segregated mode of data organization. This would require the Sashapak compression chip to write compressed data in a specific way putting the strain on the compression chip address generator. The basic principles of the new organizations are:

1. Data is organised in the MV Window in chunks of 32 sequential pixels.
- a) For 8bit U/L resolution, as one Y covers 4 pixels, 8 U/L sequential values are needed. 16bits each ->  $8 \times 16/32 = 4W$  ( $8 \times 12/32 = 3W$  for 6bit res. U/L) (where W is a 32bit word).
- b) U and V U/L data is packed together in the same word (16bits for U U/L and 16 bits for V U/L -> total 32bits=1W) and as one pair of U and V applies to 8pixels, 4 such values are needed for 32 sequential pixels ->  $4 \times 32 = 4W$ . ( $4 \times 12 \times 2/32 = 3W$  for 6bit res. U/L)
- c) The mask data is also scan-line oriented: all 32bits of Y mask of sequential 32pixels are placed in one 32bit word and due to sub-sampling on U and V, all 32bits of U and V mask of sequential 32pixels are placed in one 32bit word. So in 2W data for 32 sequential pixels on one scan line is packed. -> 2W (the same for 6bit resolution for U/L)
- d) For 640x480 window size, even at 8bit U/L resolution, data for 8 scan-lines fits in one DRAM page (symetric DRAM-s assumed):  $320WY + 80WU + 80WV = 480W < 512W$  page

Cirrus Confidential  
Business Information



f) The key to memory bandwidth optimization is the fact the the compression chip will organize data sequentially over 32 pixels instead of 8. This will be done for the mask bits which will be organized sequentially by scan line and for the U/L data. This way a 32bit word of Mask data contains only information for the current scan line and no extra memory fetches are required. The main reason we segregate U/L for Y and U/V is the fact that we want to use 6bit U/L. In this case it is easier to identify the proper U/L info chained within 32bit words if the words are sequential and we have a fix relationship between their address and the 6bit U/L quantities.

g) If we calculate now the amount of data we need to fetch to display 32 sequential pixels:

- for 8bit per U/L:  $4W(YU/L) + 4W(UV U/L) + 1W(YM) + 1W(UVM) = 10W = 40B$   
-->  $40B/32pixels = 320bit/32pixels = 10bit/pel$  to fetch from memory
- for 6bit per U/L:  $3W(YU/L) + 3W(UV U/L) + 1W(YM) + 1W(UVM) = 8W = 32B$   
-->  $32B/32pixels = 8bit/pixel$

This is a very good data fetch ratio, much better than the 16bit/pel we'd get without the optimization.

g) When reading data from the Motion Video Window the controller will generate the following sequence of addresses, all of them in the same DRAM page (8bit per U/L):

- fetch the YU/L for the first 32 pixels on scan-line n at addresses:  
MVW\_Start+n\*MVW\_Offset, +1, +2, +3
- fetch the UV U/L for the first 32 pixels on scan-line n at address:  
MVW\_Start+n\*MVW\_Offset+A0h, +1, +2, +3
- fetch the Y BitMap for the first 32 pixels on scan-line n at address:  
MVW\_Start+n\*MVW\_Offset+F0h
- fetch the UV BitMap for the first 32 pixels on scan-line n at address:  
MVW\_Start+n\*MVW\_Offset+190h
- fetch the YU/L for the first 32 pixels on scan-line n at addresses:  
MVW\_Start+n\*MVW\_Offset+4, +5, +6, +7
- fetch the UV U/L for the first 32 pixels on scan-line n at address:  
MVW\_Start+n\*MVW\_Offset+A0h+4, +5, +6, +7
- fetch the Y BitMap for the first 32 pixels on scan-line n at address:  
MVW\_Start+n\*MVW\_Offset+F0h+1
- fetch the UV BitMap for the first 32 pixels on scan-line n at address:  
MVW\_Start+n\*MVW\_Offset+190h+1
- now the MVW FIFO is full.
- chunks of ten 32bit words will be processed for every 32pixels displayed
- the MVW FIFO gets empty after the first 10 words being read for decompression and display.

Cirrus Confidential  
Business Information

Please note that all data for every 8 scanlines starting from the top of the MVW is in the same DRAM page.

Because we have to fetch the MVW Data before we start displaying it, and because at that

time the CRT FIFO does not empty as fast as it is needed (unless MS Windows is running at the same pixel depth as the MV Window), it is necessary to have a separate FIFO for the MVW or at least half the FIFO (at least 10W for 8bit per U/L and at least 8W for 6bits per U/L).

h) When we run 6bit per U/L, because the Video Memory band-width requirements are as if we were running 8bit/pel, we could do vertical zoom with averaging. But there should not be a need for zoom with Live Video because there is enough CPU and memory band-width to run 640x480 windows even when MS Windows is run as 1024x768 4 or 8bit/pel.

**Conclusion:** With Sashapak we can get data organized in memory such that the memory bandwidth is as for 10bit/pel (8bit U/L) or 8bit/pel (6bit U/L) pixel depth. The actual memory area will be close to 3bit/pel or 2.6bit/pel depending on the resolution of U/L values - 8 or 6bits per value.

Please note that the memory area will be slightly larger due to the fact that we use only 480 words in a page of 512.

#### 4.4.2 YUV to RGB Conversion Algorithm

The ideal YUV to RGB transformation is:

$$\begin{aligned} R &= Y + 1.37V \\ B &= Y + 1.73U \\ G &= Y - 0.699V - 0.336U \end{aligned}$$

After defining an objective way of measuring color error, Sasha came up with the following Conversion algorithm:

$$\begin{aligned} R &= Y + 1.375V = Y + 1.3/8V \\ B &= Y + 1.75U = Y + 1.3/4U \\ G &= Y - 0.375U - 0.75V = Y - (3/8U + 3/4V). \end{aligned}$$

This algorithm can be implemented with 8 9bit adders.

#### 4.4.2 Motion Video Architecture Functional Blocks

Instead of treating play-back and live-video as two separate modules, we'll isolate several generic functions to be used by both:

Cirrus Confidential  
Business Information

- Display Window Generation Block:

allows s/w to define one or two play-back or live video window(s).

The MV Window is defined in 4bit/pel equivalent CRT Addresses:

- MVW Start Address (19bit)
- MVW Width (max 640pixels => 80 addresses) -> CRT address after MVW on each scan line.
- The number of memory cycles to be executed at MVW pixel depth on each MVW scan-line (max 320 cycles for 16bit/pel storage at 32bit/pel pixel depth) -> scan line end.
- MVW OFFSET to the start of the next MVW Scan Line (19bit)
- MVW End Address (19bit) or MVW number of scan-lines (9 bits).

Scan-line doubling for "zoom" should be taken into account when designing DWG.

- Off-screen MV Memory Addressing and Access Control. This includes data type tag generation based on MV memory Address and the circuitry placing the tags in the CRT-FIFO. This also includes the MV prefetch cache that makes sure that there is enough prefetched MV data before starting and MV scan line display. This block has provisions for scan line replication by repeating the MV address generated on the previous scan line of the MV window (only).
- One tag bit is generated based on CRT Address and is 1 if the data in the CRT FIFO and the pre-fetch buffer is from the MVW, other-wise is 0. This tag bit, called the steering bit will be delayed through the entire data path and end up controlling the final video data mux just before the DAC
- MV Data Path and CRT-FIFO Control. This is area wise the largest piece. It consists of a new 16bit wide data-path with the same delay as the VGA data path, that takes MV data from the MV prefetch cache and the CRT FIFO, treats it appropriately depending on the MV data format encoded in the MV tags and converts it to 24 bit YUV first and 24bit RGB second. Horizontal zoom with avaraging (or maybe 5 levels of interpolation) is in this block too.
- Pre-fetch MVW Buffer - is needed in order to pre-fetch scan line data for the Motion Video Window every scan-line. Because the MS Windows pixel depth and MVW pixel depth don't match, it is necessary to fill in a separate buffer every MVW scan line before the CRT-Address Counter reaches the window boundary. The buffer will be filled first during vertical non-display time and later after each MVW scan-line display. For Sashapak this buffer has to store data for 32pixels (10x32bit for 8bit per U/L or 8x32bit for 6bit per U/L). This function can be implemented as a dynamic size modification in of the CRT-FIFO. If the CRT-FIFO has 24 stages instead of 16 but only 16 stages are used before the MVW but it is switched to 24 when MVW fetches start, there will be 8 more stages to fill at that time ensuring more prefetched data in the CRT-FIFO at the beginning of each MVW scan-line.
- Steering logic decode the tags comming out of the special addition to the CRT-FIFO and the pre-fetch buffer and controls the decompression, formarting and serialization. (they tell the formatter what data is Y, U or V).
- While switching to display the MVW the CRT Address counter continues to count at the pace set by the graphics mode outside the MVW (4 or 8 bit per pixel normally). The counter contents is compared with the MVW boundaries to detect the end of the MVW.
- What about the video serializer load and the CRT FIFO read signal? What happens to them when in VMW? They are one signal today. WHEN the data path switched to display VMW data, what happens with the VGA Video Data Path is don't care as we do not display that data, except for the h/w cursor and the h/w icon that do not go through the standard VGA serializer. So we'll probably stop the VGA data path until the point h/w cursor and h/w icon are combined into it, to save power, as we will stop the VMW data path when not in use, for the same reason.

Cirrus Logic, Inc. Confidential Information

So, the Video Serializer Load may be stopped while VMW data is displayed, but the CRT FIFO read will be going on, with a frequency and shape depending on the data format loaded in the CRT FIFO for display.

At the beginning of each VMW scan-line, the CRT-FIFO signal read will be applied only to the pre-fetch buffer and not to the CRT-FIFO itself (the CRT-FIFO read pointer won't change). Subsequently, when the pre-fetch buffer is empty (format dependent), the CRT-FIFO read will be applied to the CRT-FIFO read pointer after the data the pointer is pointing to was loaded into the VMW formatter and serializer.

In RGB 3:3:2 8bit/pel direct color mode CRT-FIFO read will be generated every 4 vclocks. In standard RGB 5:5:5 or 5:6:5 16bit/pel modes CRT-FIFO read will be generated every two vclocks.

In YUV 4:2:2 24bit/pel (Y0 U Y1 V on one scan line) the CRT-FIFO read will be generated also every two vclocks.

In Sashapak 10 (for 8bit per U/L) or 8 (for 6bit per U/L) CRT-FIFO read pulses will be generated every 32 vclocks.

- The VMW Address Counter, loaded at the beginning of each VMW scan-line with a start address calculated based on the Start VMW Address and the VMW Address Offset, will count at format dependent rate for as long as the CRT-FIFO is not full. Because the CRT-FIFO will be emptied faster in the VMW (in general the pixel depth will be higher in the VMW) there will be requests for more memory cycles when displaying in the VMW.

- If either h/w cursor or h/w icon are on, they should be displayed even if the direct data path is used. In this case both video data paths will clock and the steer tag will point to the VGA data path when either h/w cursor or h/w icon or both are displayed, even on top of a MV window. Please note that neither the h/w cursor, nor the h/w icon data go through the CRT FIFO or the VGA Data path except for the final pixel address block and the RAMDAC RAM, though they have a special path in the RAM. So we could stop most of VGA data path (including the internal palette) but not all of it even if we are in 16bit/pel mode (the new one that goes through a separate 16bit data path).

- If we are in a 16bit/pel mode with no h/w cursor or h/w icon, or in a 640x480 MVW mode filling the screen, we can stop the VGA data path to save power.

- The off-screen MVW memory will be a fix memory array towards the end of the memory, but before h/w cursor, h/w icon and the half frame buffer, even the color one. The start of the MVW memory will be fix for a memory size but it will be moving with the memory size: **2MB configuration will support enough memory to support:**

- one 640x480 3bit/pel window or up to two 320x240 3bit/pel (Sashapak) -> 32KW
- one 640x480 16bit/pel window or two 320x240 16bit/pel windows  
( $153.6KW = 614.4KB$  out of 256KW or 512KW available depending on the memory configuration).

- all of the above at the same time up to a total of two windows though.

**1MB configuration will support:**

- one 640x480 3bit/pel Sashapak window or two 320x240 Sashapak windows or
- two 320x240 16bit/pel windows.

In general, the MVW off-screen memory start address is fix, but it can grow into hfb memory if there is no hfb.

Cirrus Confidential  
Business Information

**Cirrus Logic, Inc. Confidential Information**

*We may decide to place the start of the MVW memory array at either one of two locations to optimize for TFT panels versus STN color.*

Please note that about 56KW are needed for 800x600 DS Color STN HFB, the h/w cursors and h/w icons while about 36KW are needed for 640x480 DS Color STN HFB and that

- 640x480 4bit/pel requires 38.4KW
- 800x600 4bit/pel requires 60KW
- 1024x768 4bit/pel requires 98.3KW
- 640x480 8bit/pel requires 76.8KW
- 800x600 8bit/pel requires 120KW
- 1024x768 8bit/pel requires 196.608KW

**Video Motion Formats supported are:**

- 8bit RGB not going through the palette (RGB 3:3:2)
- 16bit RGB (5:5:5 Sierra and 5:6:5 XGA) not going through the palette -> this is a 16bit/pel that does not require double dotclock !!
- 4:2:2 YUV Y0,U,Y1,V for Cinepak (or 4:1:1 if proven more useful)
- Sashapak format (Y0-ULM, Y1-ULM, Y2-ULM, Y3-ULM, U-ULM, V-ULM)

The tags that accompany the motion video data through the CRT-FIFO mark both the data format and the type of data inside the format (U/L for Y or U,V or mask for Y or U,V in Sashapak, Y0, Y1,U or V in 4:2:2).

**Note:** It may prove simpler to design a system in which the MVW is defined on the Horizontal and Vertical Counters instead of the CRT-Address. In this case, for the system to be simple we should fetch both normal CRT data and MVW data on the scan-lines on which there is MVW data. Other-wise we have to prefetch CRT data during the window.

The system would have two separate FIFO-s. A MVW will be detected during the horizontal non-display time of the previous scan line and a MVW FIFO fill will occur. Once the MVW FIFO is empty, a refill will be in order. The CRT FIFO will be refilled before the MVW ends unless the CRT FIFO cycles continue normally during the MVW, which requires a lot of memory bandwidth.

**Cirrus Confidential  
Business Information**

**CL 146384**





Cirrus Confidential  
Business Information

#### 4.5 Feature Connector Support

Nordic-1M will support 5428 Feature Connector so that it is compatible to Media Manager.

Nordic-1M will support VAFC (Vesa Advanced Feature Connector) in the 8bit VSVPC passthrough compatibility mode.

The main difference between 5428 FC and Nordic FC is the fact that 5428 FC has one EDCLKn control pin controlling the direction of the DCLK pin, while Nordic-1M as well as VAFC have a FCDCLK output pin and a FCVCLK input pin.

Dave Keene believes that 5428 FC is VAFC compatible. To ease the design, I kept 5428 FC pin names (not VAFC pin names).

On VAFC compatibility here are some comments:

- GENCLK can be applied on XVCLK if SR22[3]=1.

But, if SR22[3]=1 (select xclk) & SR24[7]=1 (VAFC enabled), then XMCLK should get OSC and MCLK Synthesizer operates normally, except that the reference frequency comes from XMCLK instead of OSC pin. If SR22[3]=1 & SR24[7]=0, then MCLK comes directly from XMCLK pin and the MCLK and VCLK Synthesizers are powered-down !!

- GRDY signal is similar to OVRW.

- VRDY is similar to EVIDEO if EVIDEO is dynamically switched as a valid data signal.

- EGENn is not needed if we configure Nordic-1M in the right configuration with SR22[3] (XCLKPU) and SR24[7] (VAFCPU).

- As VAFC maximum FCVCLK frequency is 37.5MHz, VAFC supports a mode in which data is sent at 37.5MHz to the DAC and each pixel will be displayed twice if the chip is running at 75MHz pixel clock. This allows only 8bit/pel data to be displayed. To display 16bit/pel data we should use both phases of the FCVCLK and pack the data into one pixel. I think that this is already done in 5428, if not Man-Shek and Fong-Jim are modifying the 5429 RAMDAC to support this mode -> we need to support it too.

- VAFC requires FCDCLK to be switchable under s/w control between 1x and 1/2x the pixel clock. If we took this out of Nordic-1M data base, we should put it back, but the divide by two should affect only FCDCLK going out of the chip.

Check VESA VAFC Proposal 1.0p rev. 0.31 07/15/93 for VAFC timing info.

#### Nordic-1M FC Pins Functional Description

Cirrus Confidential  
Business Information

Most of this is from 542X Data Sheet page 3-26:

**VSYNC and HSYNC** TO The standard CRT pins tri-stated when FCESYNCn is L. These pins have programmable polarity.

**FCBLANKn** I/O BLANKn in 5428. If FCESYNCn is H, this is an output and it supplies the actual composite BLANKn CRTC signal. VAFC requires this to be the composite Display Enable (no borders). If this is the case, we'll need a bit for VAFC that puts DE = HDE & VDE inverted on BLANKn.

If FCESYNCn is L. FCBLANKn is an input and it forces RAMDAC RAM outputs to 0'(black), but it should force them black before they go to the panel.

*It seems that by connecting OVRW output to BLANKn as input we can display FC data in a window - this will work though only if OVRW internally controls the pixel address mux between normal VGA data and the FC data.*

FCP[7:0] I/O P[7:0] in 5428.

If FCEVIDEOn is H, these pins are outputs and represent the pixel address of the RAMDAC.

IF FCEVIDEOn is L, these pins are inputs and represent the pixel address to the RAMDAC.

CR1A[3:2] control the way the FCP[7:0] are muxed with the normal data.

FCDCLK O (the actual pin is I/O) outputs VCLK or VCLK/2 if selected through s/w.  
FCESYNCn I ESYNCn in 5428. Controls HSYNC, VSYNC and FCBLANKn

(H-> outputs, L-> H/VSYNC are tri-stated.  
FCBLANKn is tri-stated.).

Nordic does not have EDCLKn input as FCDCLK and FCVCLK are not shared.

OVRW O OVRW in 5428 = Overlay Window. This active Low signal, is generated by the BLANKn VT and HT logic (shared) and is supposed to be used to create an Overlay Window in which data from the Feature Connector is displayed. *I don't know why we output this signal. It should be controlling the MUX between the normal pixel address and the FC originated pixel address.*

#### 4.6 On WavePort Architecture and Audio Driver

Starting from Dave Keene's WavePort Specification, Rakesh, Sasha and Vlad came-up with some ideas which could greatly simplify the design work for WavePort, reduction the complexity and the number of gates of the WavePort.

We'll start with the small issues and move towards more important issues. Cirrus Confidential Business Information

##### 4.6.1 AUXS1 and AUXS2 Pin

A. Dave proposed to share this pin with PDN (Power Down) WavePort Pin and configure it as AUXS2 when using 4231S.

We noticed that 4231S does have a PDN pin which we'd like to use to save power. We'll put AUXS2 on another pin.

B. Dave proposed to have a fully programmable location for AUXS1 and AUXS2 CPU I/O map with a default at 530H and 388H. This is costly (4 registers and fast comparators) and very difficult to design at required speed: will slow down address range decode for I/O a lot affecting command to command parameters.

We suggest to have a fix address for these ports: 530H and 388H.

Two register bits (one per address) can disable the chip from answering to these I/O

addresses.

If we are not sure where to place these ports, we can leave it as a metal option for future modification or have one more alternative for each, but the address should be fix for fast decode.

GR58:GR5B are no longer needed if this option is accepted. We'll need two bits to disable 530H and 388H address decode and eventually two other bits to select other two alternate I/O addresses. We should always decode 16 addresses: 530:53F and 388:397 (not 4 or 16).

#### 4.6.2 WavePort R/W Buffer Location and Size

To simplify the h/w and reduce verification work-load, WavePort R/W Buffer Size should be fix: 32KB for each, enough for at least 180msec of operation -> 90msec for half buffer. Every 90msec the CPU will have to fill and/or empty half Audio Buffer (write or read respectively).

It is also possible to place the WavePort memory buffer in a fix memory location, common for both desktop and portable architectures. We could place it in Memory in the upper part (in high address area), just before the h/w cursor. If the h/w cursor takes the upper 16KB of the memory, we could use the next 64KB for the WavePort buffer.

Going down in memory, in Nordic we'd place the h/w icon in the next 16KB (only 4KB needed now... but leave some room for expansion) and the Half Frame Buffer for monochrome and color panels in the next 32KB and 96KB respectively.

**Total:**

96KB for CRT/TFT/SS STN panels,  
128KB for monochrome panels and  
192KB for dual scan color STN panels.

out of 1MB or 2MB memory available.

When the memory is expanded, all these fix components should move automatically in the upper side (towards the end of memory).

This places the WavePort buffer at:

- for 1MB of memory by 32 (256Kx32 -> 00000:3FFFF) 3B000:3EFFF
- for 2MB of memory by 32 (512Kx32 -> 00000:7FFFF) 7B000:7EFFF

If we adopt this solution, GR43 is not needed.

Cirrus Confidential  
Business Information

#### 4.6.3 On Host Access to WavePort Buffer

In order to ensure independence between the Graphics s/w Driver and the Audio Driver, taking into account AVGA limitation of no CPU accesses during BLT operation, Dave proposed a separate path for WavePort Host Accesses. This involves a separate 4 stage by 32bit write and read buffer and separate arbitration for the Audio cycles. The buffer is shared by WavePort read and write operations and an I/O to an extension register bit is needed in order to switch from a read operation to a write operation or vice-versa. Dave also proposed that the host address be dependent on GR6 CPU address map bits such that the video and audio address maps don't overlap. Please note that this approach prevents debug with a Hercules card when in graphics.

In the following an alternate scheme is proposed:

- There is one register bit that enables WavePort memory write accesses and one register bit that enables WavePort memory read accesses. When one of these bits is asserted the chip expects only host accesses for the WavePort: the host address will be automatically translated to a memory address inside the WavePort buffer. The access will be fully linear. 32bit only, **graphics mode independent** (like in extended 8bit/pel). The Graphics block will be forced to this mode and all planes will be automatically enabled. On the Host side, the WavePort buffer will be placed always at A000:0000 - A000:FFFF -> 64KB with 32KB for read buffer (the upper side) and 32KB for write buffer (the lower side of this 64KB segment).
- The CPU Data Path is the same as for any other CPU cycle: no special FIFO, no special arbitration are required. The Audio Driver and The Graphics Driver communicate through interrupts: There is an interrupt for BLT completed (Dave's idea when presented with this proposal) and an interrupt for Audio Buffer Full (or Audio Transfer Completed). When the BLT is completed, if Audio is enabled on the chip, the BLT Completed interrupt allows the Audio Driver to check if there is any need to service the Audio and vice-versa. If possible, the Graphics driver should restrict the extent of the BLT operations to less than 160msec or so (leaving at least 20msec to start filling the WavePort buffer).
- There is no on chip CPU WavePort address generation. The CPU address in the range A0000:AFFFF (incremented by 4 every cycle for DW accesses) is translated to physical memory address 3B000:3EFFF. If host side WavePort pointers are used, the host address is latched and translated for comparison with the Codec pointers generated on chip.

Adopting this scheme would greatly simplify the extent of the design and verification work for WavePort: 8 weeks at least will be saved.

Cirrus Confidential  
Business Information

#### 4.6.4 On the Audio Driver

Dave proposed that the Graphics Controller has h/w to compare the WavePort pointers and generate interrupts. The Codec pointers are I/O readable by the host as well as several buffer status bits (Audio-IN buffer Full, Audio-In buffer half-full, Audio-Out buffer half-empty, Audio-Out buffer empty,...).

Nordic-1M will support Dave's proposed interrupt driven interface. In this case the only important difference for the driver will be that it will have to generate the buffers address and not rely on the h/w to do this (Dave suggests that CPU will write and read always the same address A000:0 or B000:0 and the actual address on the host side is generated on the chip - we suggest to change this and let CPU generate the address).

Because CPU has to wait until the a BLT operation is complete and the BLT has to wait for Audio buffer to be full or the transfer completed, two more interrupts are needed: BLT operation completed and Audio transfer completed. This way the Audio Driver and the Video driver can communicate with each other.

Cirrus Logic, Inc. Confidential Information

The Read and Write CPU side pointers will be generated by latching the last read and write WavePort CPU address (lower 16bits only) after translation to physical memory address. Comparators on the host and codec pointers will generate Buffer Full and Buffer Empty signals.

Jeff Orr drew our attention to the fact that the driver transfers a certain size block and needs an interrupt anytime half of what was placed in the Audio buffer was read by the Codec (the play-back buffer is half empty). To make things simple for the h/w, we propose to give Jeff an interrupt when the CODEC side playback buffer read pointer reached a pre-programmed value, value the driver programs everytime it transfers a block of a certain size in the playback buffer. For instance, if the driver put 2KB of data in the playback buffer starting from physical address 3B000 (host address A000:0) and wants an interrupt when the first 1KB was read by the CODEC, it should program 3B0FF in the playback interrupt register, as  $1KB = 256$  32bit words. The register will have 16bits and the driver will program B0FF to get an interrupt when the CODEC reads 3B0FF or 7B0FF playback buffer address.

Similarly, on the record side, there will be a programmable interrupt on the CODEC side to be used to tell the driver when the Record buffer is half full. So we'll need two 16bit indexed registers for these programmable interrupts. For each WavePort interrupt we also need a status bit to say that the interrupt happened, an enable bit to enable the particular interrupt. As Dave proposed, GR4D is the Interrupt Status register but bits [0] and [2] will be the programmable interrupts status bits. The interrupts and the status bits will be cleared after this register is read (automatic clear in h/w).

We could use registers GR58:5B as high and low byte for the programmable interrupt on Record and Play-back buffers respectively.

The write-buffer (or Audio-Out = the one in which the CPU writes) is empty one WavePort write cycle to memory after

WRBUF-Write-Pointer = WRBUF-Read-Pointer + 1  
(this condition will activate set an empty flag).

Cirrus Confidential  
Business Information

The write-buffer is full one WavePort write cycle to memory after  
WRBUF-Read-Pointer = WRBUF-Write-Pointer + 1

The same equations apply to the WavePort read-buffer, only this time the read-pointer is on the host side and the write-pointer on the Codec side.

*Shouldn't be a Audio-Out buffer full interrupt and a status bit for it?*

Threshold detect mechanism will require to increment host pointers, but the CPU is supposed to read this pointer and generate the proper address when going above the threshold. The idea of the threshold detector is that by incrementing the Audio-In read pointer everytime the write pointer is incremented if the Audio data is under the threshold value, the delta between the pointer remains the same and the buffer does not fill in with sub-threshold value. This was true if the half-full detection had been generated based on the delta between pointers. After talking to Dave, there are some clarifications to be made on the threshold detect mechanism for record:

Cirrus Logic, Inc. Confidential Information

For one record session, this is a one time event mechanism: if the threshold was passed once after being enabled, its effect is lost - even if the sound level goes below the threshold the record buffer read pointer works normally. The threshold will help only in the initial stage before the first actual voice pattern is detected, but it does not have any effect after the initial triggering event - once the sound level passed once the threshold.

With this driver approach, GR43 and GR58:5B will not be needed.

Five registers are saved. Twenty One register are still needed (plus two reserved = 23).

**Another possible approach for the driver uses extensively the Vertical Interrupt:**  
In this case every Vertical Interrupt, the Audio Driver reads the Codec side pointers, compares them with the Host side pointers, the driver generates based on the CPU address it last wrote to or read from and makes its own decisions. The driver will also check the BLT completed status bit.

In other words, every 18msec (@60Hz), on the Vertical Interrupt the Audio driver can process data from the Codec pointers, calculate based on the last address if the WavePort buffer is full or empty and decide how many more WavePort accesses to execute. As at least 180msec worth of data is in a full Waveport Buffer, the driver has 6 opportunities to find out that the buffer is empty and start filling it before half WavePort buffer is empty. On chip h/w is still needed to stop sending data to the Codec after sending all data and to read all data from the WavePort read memory buffer on the host side. Because the CPU decides when the buffers are full, half full or empty there is no need for registers for the pointers on the CPU side, but the CPU address will still be latched to generate the host side pointers.

The "BLT operation completed" and the "Audio transfer completed" interrupts are needed anyway because we share the data-path for BLT and CPU cycles.

By adopting this mechanism in the driver, no special h/w is needed to preserve pointers on the Host side, to compare the Host side pointers (read and write) with the Codec pointers and to generate interrupts and status bits. The only interrupts needed are Standard VGA Vertical Interrupt as a time base, BLT completed Interrupt and Audio Completed interrupt.

We can still implement the threshold detect.

GR44, GR45, GR48 and GR49 won't be needed.

Nine registers are saved. Seventeen register are still needed (19 with two reserved registers).

Cirrus Confidential  
Business Information

Conclusion

The above proposal, if OK for the WavePort driver, would reduce significantly the amount of design and verification work on the WavePort. This document was written in order to get feed-back and reach an agreement ASAP. Our goal is to have a unique s/w model for the WavePort, but we'd like to cut the amount of work if possible.

## Cirrus Logic, Inc. Confidential Information

Nine registers are saved. Seventeen register are still needed (19 with two reserved registers).

### Conclusion

The above proposal, if OK for the WavePort driver, would reduce significantly the amount of design and verification work on the WavePort. This document was written in order to get feed-back and reach an agreement ASAP. Our goal is to have a unique s/w model for the WavePort, but we'd like to cut the amount of work if possible.

## 4.7 Four Bit per Pel Packed Format

To fully support Windows Chicago, Nordic-1M should support 4bit/pel packed format. CPU will be able to write only 8bits or more at a time. To modify only 4bits the CPU will do read modify write and mask four bits (bring them from CPU latches).

The following picture shows the actual format:



In order to get Nordic-1M to support this mode, we need to place the VGA Video Data Path in 8bit per pixel mode with pixel doubling (mode 13) but disable the mechanism that concatenates adjaisant 4bits to make one 8bit pixel displayed twice (at a divided by two RAMDAC VCLK) and disable as well dividing by two the RAMDAC VCLK.

On the CPU side chain 4 address scrambling should be disabled and data should be shifted right like in extended 256 color modes.

In nordic-reg9.lst we assigned SR26[0] to enable this graphics mode.

Cirrus Confidential  
Business Information

## 4.8 Robin's Ideas on High Resolution Panels for Nordic-1M

CL 146393

Nordic's objective is to be able to center and fill the screen on 800x600 panels and to center an 800x600 picture on 1024x768 panels. The main focus is 800x600 panel support TFT and dual scan STN.

In TEXT there will be three options:

- horizontal and vertical centering with 9x16 fonts (disable 640x480 force to 8dots font)

#### 4.7 Four Bit per Pel Packed Format

To fully support Windows Chicago, Nodric-1M should support 4bit/pel packed format. CPU will be able to write only 8bits or more at a time. To modify only 4bits the CPU will do read modify write and mask four bits (bring them from CPU latches).

The following picture shows the actual format:



In order to get Nordic-1M to support this mode, we need to place the VGA Video Data Path in 8bit per pixel mode with pixel doubling (mode 13) but disable the mechanism that concatenates adjacent 4bits to make one 8bit pixel displayed twice (at a divided by two RAMDAC VCLK) and disable as well dividing by two the RAMDAC VCLK. In nordic-reg9.lst we assigned SR26[0] to enable this graphics mode.

#### 4.8 Robin's Ideas on High Resolution Panels for Nordic-1M

Nordic's objective is to be able to center and fill the screen on 800x600 panels and to center an 800x600 picture on 1024x768 panels. The main focus is 800x600 panel support TFT and dual scan STN.

In TEXT there will be three options:

- horizontal and vertical centering with 9x16 fonts (disable 640x480 force to 8dots font)
- auto-expand the font to fill the screen
- special font to fill the screen

In Graphics there will be three options:

- horizontal and vertical centering
- use a driver to run at maximum resolution
- automatic expand to 800x600 (only if s/w verification shows it being OK).

In all cases horizontal and vertical options will be decoupled (different enable bits).

Here's a list of what needs to be done:

- a. Expand horizontal and vertical centering capability from 640x480 to 1024x768.
- b. Shadow all H/V CRTC registers except HDE and VDE.

Cirrus Confidential  
Business Information

Cirrus Logic, Inc. Confidential Information

The vertical registers are shadowed now, but the horizontal registers are not. We need to shadow CR0, 2, 3, 4 and 5. These registers will be written by the BIOS at POST.

c. Support 10dot character-clock and CRT-FIFO-Read / Shift/Load (Video-Serializer Load). Now only 8dot and 9dot character-clocks are supported. For smooth-scrolling the pel-pan has to be expanded to 10 positions (0:9).

d. TEXT auto-expand will be as follows:

- horizontal: replicate the last pixel once for 9 dots wide fonts and twice for 8 dots wide fonts.
- vertical: replicate all odd scan-lines

TABLE 3. Font Expansion for Different Panel Sizes

| Font-Size/Panel-Size       | 480  | 600   | 768            |
|----------------------------|------|-------|----------------|
| 8x14                       | 8x19 | 10x21 | 10x21 + center |
| 8x8 with scan-in. doubling | 8x19 | 10x24 | 10x24 + center |
| 9x16                       | 8x19 | 10x24 | 10x24 + center |

Please note that in text vertical expansion is done on the scan-line counter as well as the vertical display line counter, but it does not affect the vertical non-display line counter.

e. Graphics modes expansion (to be implemented only after s/w verification)

Graphics expansion is less important as it is assumed that important applications will run at maximum panel resolution with a driver.

We'll need to supply drivers for many applications with high res. panels !!

Vertical expansion:

- 350lines -> replicate all odd scan-lines
- 400lines -> replicate all odd scan-lines
- 480 lines -> replicate every 4-th line

Horizontal:

- center
- duplicate every 4-th pixel
- duplicate every 4-th pixel with diagonal shift

(scan-line 0 -> 1st pel, scan-line 1 -> 2nd pel, scan-line 2 -> 3rd pel, scan-line 3 -> 4th pel).

## 5.0 Nordic-1M Pinout Specification 208 pin package:

Cirrus Confidential  
Business Information

CL 146395

System Interface (reference is VESA VL bus): 73

(on BVDD)

DAT31:0

HIMEM (normally used as ADR24, but it can be used as ADR31 and leave 2GB of upper address space reserved for MPEG/JPEG boards)

ADR23:2

BE3n.BE2n.BE1n.BE0n

LADSn.LDEVn.RDYn

M/IOn, W/Rn

RESET, LCLK

RDYRTNn,

EBROMn/VADRn/AUXS2 (Enable BIOS ROM Buffers on all busses or Valid Address - CPU Address in Nordic valid address range I/O or memory or Auxiliary Select 2 to be used to select the Audio Synthesizer or some other audio chip)

INTR, CLK32K/OVRW, OSC/XVCLK (14.318MHz)

SUSPIn/BLIn/FCBLANKn, SBYIn/ACTIn/FCEVIDEOIn

(32KHz clock input / FC Overlay Window Output controlled by VAFCPU,

Suspend Input/ Back-Light Input/VAFC BLANKn I/O signal controlled by VAFCPU - pin configuration -and FCESYNCn - FCBLANKn direction and HSYNC/VSYNC HI-Z or not;

Stand-by Input/Activity Input/VAFC External Video Control Input - controls the direction of FCP[7:0]. Pin configuration controlled by VAFCPU).

Configurations: - VL/PCI/ISA bus, support/not BIOS, 8/16bit BIOS.

- Need a register bit to select SUSPEND Input or Back-Light Input. Default is SUSPEND Input.
- Need a register bit to select Stand-By Input or Activity Input. Default is Stand-By Input.
- SUSPIn, BLIn, SBYIn, ACTIn are level triggered, active L inputs. In Nordic there is no Suspend pin polarity bit as in T1 (SR8[4]).

Note: a. In PCI bus, Alpine used ADR17:2 as BIOSA15:0. We assume that all portable systems will use a motherboard video BIOS and do not support an adapter BIOS in PCI. We do support an adapter BIOS in VESA VL bus and ISA to facilitate demo board design.

b. EBROMn is active on all bus types: in ISA is generated on Address Decode and MEMRn, while in VL and PCI is unlatched address decode. In PCI bus the BIOS should be relocatable, an option we do not support. That is why we say that we do not support BIOS in PCI. We do support IOCHRDYn and RDYn/TRDYn for BIOS accesses too. All this logic should already be in 5428 (ISA and VL) and Alpine (PCI).

c. The 5428 Feature Connector pins are available in all buses. A register bit enables them early in the logic to save power when not in use.

Cirrus Confidential  
Business Information

CL 146396

Cirrus Logic, Inc. Confidential Information

DRAM Interface (for asymmetric, dual WEn 256Kx16 DRAM-s): 50  
(on DVDD)

MA9:0

MD31:0

RAS0n.RAS1n.CASn/WEn. OEn

WE0n/CAS0n,WE1n/CAS1n,WE2n/CAS2n,WE3n/CAS3n

Configurations: symmetric/assymmetric DRAM, dual WEn/CASn

Note: a) For dual CASn DRAMs, the WE0n:WE3n pins become CAS0n:CAS3n, while CASn becomes WEn.  
b) Two RAS-es are used for two banks.  
c) OEn is not actually needed as we use early write.

Clock Synthesizers: 6

(MAVDD, MAVSS feed mclk clock synthesizer, VAVDD, VAVSS feed dclk clock synthesizer)

MAVSS, VAVSS, MAVDD, VAVDD,

MFILTER, VFILTER

(Can we design a clock synthesizer without an external filter?)

CRT Interface and RAMDAC related pins: 10

(DAVDD, DAVSS feed all RAMDAC custom layout)

R,G,B (analog)

IRef, DCVDD1, DCVDD2, DCVSS1, DCVSS2

HSYNC, VSYNC TO (these two pins are on BVDD )

FLAT PANEL and Power Management Interface (on PVDD): 31

R7/FCP[3], R6/FCP[2], R5:0, G7/SUSPSTn/FCP[1]

G6/SBYSTn/FCP[0], G5:0, B7/MOD, B6/FCVCLK, B5:0

(use slow edge pads and stagger them modulo 4)

FPVDCLK, LLCLK, LFS, FPDE, (use slow edge output pads)

FPVCC, FPBL, FPVEE

Cirrus Confidential  
Business Information

Notes:

CL 146397

b. R7:6, G7:6, B7:6 (24 bit TFT panel extra video data out pins)

c. We need also bits for SUSPST and STANDBYST, PANEL-ON/OFF, PANEL-IN-POWER-UP-or-DOWN.

d. We assume that the 24bit TFT panels do not need external MOD.

- e. No NPD pin.
- f. FCP[3:0] pins are I/O-s whose direction is controlled by FCEVIDEOin in VAFC configuration. FCVCLK is the clock that clocks them in and which should be used to clock them while they are displayed or at least to resynchronize them before being latched on the internal clock. FCVCLK is always an input when in VAFC configuration.
- g. Nordic-1M facilitates NTSC output by providing RGB 6:6:6 just before DAC on the R5:0, G5:0, B5:0 when in a special mode. It also provides odd/even frame signal and true Display Enable in sync with the RGB. Nordic-1M will run in terlaced mode when in NTSC Out mode. All the needed signals will be comming out on the Flat Panel Pins in the NTSC Out mode.

Audio Port (on ADVDD): 6

SDO (SErial Data Output to CODEC pin SDIN)

SDI (Serial Data input from Codec pin SDOUT)

FSYNC (Frame Sync Output)

SDCLK (Serial Data Clock I/O )

D/Cn/AUXS1 (Data/Control Select Output or CS4231S Chip Select for the ISA bus)

PDN (Power Down Output)

Note: These pins can be used as extensions for 24 bit TFT panels. in which case the chip does not support the audio port. Note also that CS4215 has Resetn pin.

Cirrus Confidential  
Business Information

Miscellaneous Pins: 10

Following pins on MVDD:

TRWn I (Test Latch Load Enable, active L - for pinscan & test mode)

SW2 I (Switch #2 or reserved for SDRAM support in the future)

SW1/MCLK/XMCLK I/O with PD controlled by XReset

(Switch #1 or mclk driver buffered output for testing and debug or external mclk for testing; a special register bit disables this output in normal operation for power savings.)

Default: Input on which either SW2 or XMCLK comes in.

Only if the special register bit is set, this input becomes output and outputs MCLK from the clock synthesizer for testing.

The special register bit defaults 0 = the pin is configured as Input. Please note that a h/w configuration PU/PD controls if the actual internal mclk comes from an internal or external source, but this PU/PD does not control if

SW2/MCLK/XMCLK is an input or an output.)

RES4CKE O NC Pin Reserved for Future Nordic chips

Following Pins on BVDD:

SW0/VCLK/FCDCLK I/O (Switch #0 Input or vclk driver buffered output for testing and debug, or VAFC Dot-Clock Out :  
Default for this pin is Input on which SW#0 is applied.  
VCLK and FCDCLK is the same signal, the name is different to ease reference to VAFC spec )

Following Pins on PVDD:

FCP[7:4] I/O Feature Connector Data Pins bits 7 to 4.  
The other Feature Connector pins are shared with some panel or host bus pins.

FCESYNCn/RES4SDCLK I 5428 Feature Connector ESYNCn pin - controls the direction of FCBLANKn and its effect and tri-states HSYNC and VSYNC.

#### System/Bus Interface Signal Mapping

(See 54xx Reference Manual for Feature Connector Pins Description: FCyyyy)

TABLE 4. VESA-VL <> PCI bus <> ISA bus Pin Mapping

| VESA-VL  | Intel-PCI | ISA         |
|----------|-----------|-------------|
| HIMEM    | --        | --          |
| ADR23:16 | --        | LA23:16     |
| ADR15:9  | --        | SA15:9      |
| ADR8     | PAR       | SA8         |
| ADR7     | STOPn     | SA7         |
| ADR6:2   | --        | SA6:2       |
| BE3n     | C/BEn3    | SA1         |
| BE2n     | C/BEn2    | SA0         |
| BE1n     | C/BEn1    | SBHEN       |
| BE0n     | C/BEn0    | RFRSHn      |
| DAT31:22 | AD31:22   | --          |
| DAT21:19 | AD21:19   | --          |
| DAT18    | AD18      | MWRn        |
| DAT17    | AD17      | IOCS16n     |
| DAT16    | AD16      | IRQ         |
| DAT15:0  | AD15:0    | SD15:0      |
| RESET    | RESET     | RESETDRV ?? |
| LADSn    | FRAMEn    | BALE        |
| LDEVn    | DEVSELn   | MCS16n      |
| RDYRTNn  | IRDYN     | AEN         |

Cirrus Confidential  
Business Information

CL 146399

TABLE 4. VESA-VL <> PCI bus <> ISA bus Pin Mapping

| VESA-VL      | Intel-PCI | ISA         |
|--------------|-----------|-------------|
| W/Rn         | IDSELn    | IORN        |
| M/IOn        | --        | MRDn        |
| LCLK         | CLK       | IOWn        |
| RDYn         | TRDYn     | IOCHRDY     |
| EBROMn/VADRn | VADRn     | EROMn/VADRn |
| INTR         | INTR      | ZEROn       |

Notes:

1. SW2, SW1/MCLK/XMCLK and SW0/VCLK pins are normally used by the BIOS as panel type switches readable on SR24[2:0].
2. XMCLK and XVCLK (on OSC/XVCLK) are needed for manufacturing test of the chip. When they are used, SR24[1:0] will wiggle at clock rate and they should be masked on the tester.
3. MCLK and VCLK are needed for manufacturing test of the clock synthesizer and for chip debug.

Digital Mixed Voltage Power Pins: 22

BVDD1, BVDD2, FPVDD1, FPVDD2, MVDD1, MVDD2, ADVDD, CVDD1:4, (BVDD goes now to HSYNC and VSYNC)  
VSS1:11

Total Pins Used: 208 (with no pin left).

Cirrus Confidential  
Business Information

Pinout Modifications in rev. 3.8 relative to rev. 3.7 09/11/93

1. Took-out Whisper Support Pins: WWRn, WRdn, WAD[3:0], FPCn. CL 146400
2. Reduced the number of CPU Address Pins: ADR[24:27] went-away. Use HIMEM to place the chip outside 16MB of memory for linear addressing.
3. Killed CRTVDD and placed CRT Interface on Host Bus VDD.
4. Introduced VAFC pins in a unique pinout configuration in both VESA VL and PCI. Added VAFCPU a pull-up to enable VAFC (VESA Advanced Feature Connector). ADR[27:24] VAFC pins, and R[7:4], G[7:6], EROMn/VADRn, SUSPI/BLI, SBY1/ACT1 get a configuration for VAFC -> total 14 pins. SW0/VCLK will be used as VAFC VCLK, losing SW0 pin as panel type when VAFCPU is used.  
In PCI bus, no ADR pin will be shared with VAFC.  
ASW0PU (Alternate Switch 0) will be added on MD pins to replace SW0 pin when VAFC is enabled by VAFCPU. ASW0PU will read-back in the same register bit as SW0.

so the BIOS will not feel any modification in the reporting scheme. The chip will draw more power in suspend with VAFC.

5. Moved SW2, SW1/MCLK/XMCLK the two reserved pins (one obtained by killing CRTVDD) and TRWn on MVDD to prepare for SDRAM pin compatible option in the next Nordic that supports SDRAMs. Marked them as "reserved for SDRAM pin name". It looks that TRWn will not be needed, but it was moved on MVDD so that in case it is needed, it is available (in this case we'll need an extra switch for SDRAM support or at least to disable TRWn test mode effect).

6. Rearranged VAFC pins as pins R4 and R5 were used by VAFC - an error.

### Configuring Nordic-1M

If Terminator used specially assigned pins to configure the chip, Nordic-1M will use some of the MD31:0 pins sampled on the Reset trailing edge, similar to Mustang. The pad cells will have an active pull-down controlled by an extended Reset signal. The pull-down resistance will be about 75KOhm. An external pull-up less than 60KOhm is needed only if the option is used. In Suspend, the MD pads are inputs and the DRAM OEn is H so no DC current is drawn by the configuration h/w. An external resistor is needed only if the configuration pin has to be H at Reset.

All h/w configuration latches are read accessible via I/O. The h/w configuration is latched on Reset trailing edge. (these latches were r/w, with s/w PU read, having only read is enough).

We'll define the configuration pins to minimize the number of external resistors:

#### CPU Bus Configuration:

|                                |                                                                                                                                    |
|--------------------------------|------------------------------------------------------------------------------------------------------------------------------------|
| On MD18:16 & -> no external PU | = 32bits VESA VL bus at 33MHz or less bus clock                                                                                    |
| & MD23                         |                                                                                                                                    |
| -> MD16 PU                     | = 32bits PCI bus with Burst <u>PU called "PCIPU"</u>                                                                               |
| -> MD17 PU                     | = 16bits ISA bus <u>PU called "ISAPU"</u>                                                                                          |
| -> MD18PU                      | = 32BIT VESA VL BUS AT 50MHZ BUS CLOCK <u>PU called "FVLPU"</u>                                                                    |
| -> MD23 PU                     | = 32bits PCI bus no Burst <u>PU called "PCINBPU"</u><br>This is a reserved configuration in case burst does not work on a PCI bus. |

#### Reads-back in SR22:

PCIPU on MD16 -> SR22[0]  
ISAPU on MD17 -> SR22[1]  
FVLPU on MD18 -> SR22[2]  
PCINBPU on MD23 -> SR22[7]

Cirrus Confidential  
Business Information

CL 146401

**Clock Configuration:**

- | On MD19 (reads back on SR22[3])
  - > no external PU = internal MCLK and VCLK clocks, from the internal clock synthesizer
  - > MD19 PU = use external clocks from SW1/MCLK/XMCLK and OSC/XVCLK  
PU called "XCLKPU"

This PU is used for manufacturing test.

One reg. bit is needed if internal clock is selected to control outputing mclk on the MCLK/XMCLK pin = 1 if use internal clock then output it on SW1/MCLK/XMCLK pin. -> SR23[0] is this bit.

**Memory Configuration: SRF[0]**

No Pins, Use Two Register Bits -> 2CAS/2WE bit=H 2WE, bit=L 2CAS (default =L)  
-> Symetric/Asymmetric bit=H Asym., bit=L Sym.  
(default=L)

- | **BIOS Support:** (reads-back on SR22[6] for BIOS8PU)

Nordic-1M supports 16bit or 8bit BIOS and only in ISA bus configurations.  
The BIOS is always supported when in ISA.

On MD22 -> no external PU = 16bit BIOS  
-> external PU = 8bit BIOS (no MEMCS16n decode on C000)  
This option is mostly for debug in case 16 bit BIOS range decode is not fast enough.  
If the BIOS support is disabled, this configuration is don't care. Called "BIOS8PU".

- | Please note that Nordic-1M supports C000 BIOS only in ISA.

In a normal note-book the BIOS is at E000:0, not supported by Nordic: so no external component is needed.

**Sleep Address Selection:**

On MD21: **Sleep Address Selection** (reads-back on SR22[5]).  
-> No external PU = sleep at 3C3[0] - to be used when Nordic is on the Mother-board (most cases)  
-> External PU = sleep at 46E8[3] - to be used when Nordic is an adapter (like a PCMCIA card and/or an adapter to turn desktop into an environment friendly PC) Called: S46PU

**Cirrus Confidential  
Business Information**

| Note that Nordic-1M comes-up awake, though this has to be cleared with the BIOS group.

Feature Connector Configuration: (reads-back on SR24[7])  
On MD25:

-> No external PU = no Feature Connector Support: outputs used only for FC are forced L. I/O are forced inputs. I/O and inputs are forced on the chip so that they do not take power if not connected externally.

-> External PU = All pins needed for FC including OVRW are active.  
Called: VAFCPU

On MD26: Alternate SW0 Selection (Reads-back on SR24[0] when SR24[7] is 1)  
When SR24[7] is 1, SW0 pin is forced to output DCLK and this external PU latched on Reset trailing edge plays as SW0. It reads back at the same bit as SW0 does.  
-> No external PU = SW0 reads back 0 in SR24[0]  
-> External Pu: SW0 reads back 1 in SR24[0].

| Total: 10 H/W PU configuration options.

In normal operation with FC enabled up to three external PU-s may be needed (bus type if not VL and FC).

In normal operation with FC disabled up to one external PU-s may be needed (bus type if not VL and FC)

Summary of PU/PD Configuration Pins and Register Bits where they can be read-back:

**SR22 [7:0] H/W Configuration Read Register #1**

Read only register, written on reset trailing edge by activating PU/PD on MDi pins. The PD-s are inside the pads active only during XReset (extended reset).

| [7] 32bits PCI bus no Burst h/w PU configuration on MD23. It is called "PCINBPU"  
(read only bit).

This is a reserved configuration in case burst does not work on a PCI bus.

| [6] Select 8 bit BIOS support (if 1). Otherwise 16 bit BIOS support if the BIOS support is at all enabled. PU on MD22.

Cirrus Confidential  
Business Information

[5] Reserved for Sleep Address Select: reads back S46PU (MD21).  
1 = I/O address 46E8[3] as sleep address (needs external PU).  
0 = I/O address 03C3[0] as sleep address (no external PU is needed).

CL 146403

| [4] Reserved

[3] Select external clocks: MCLK and VCLK on SW1/MCLK/XMCLK and OSC/XVCLK. (default: internal clock synthesizer, SW1 and OSC).

| PU on XCLKPU on MD19.

0 = internal clocks with the pins used as inputs for panel type switch #1 and OSC.  
If SR23[4] and SR23[0] are 1, SW0/VCLK and SW1/MCLK/XMCLK  
respectively become VCLK and MCLK outputs respectively, for test purposes  
(only if SR22[3]=0 MCLK can be seen, but VCLK can be seen even if SR22[3]=1  
as long as SR23[4]=1)

1= SW1/MCLK/XMCLK and OSC/XVCLK become XMCLK and XVCLK inputs  
generating directly chip MCLK and VCLK without clock synthesizer. The clock  
synthesizers are powered down if SR22[3]=1.

[2] Select VESA VL Bus at 50MHz

| 1 = VESA VL bus at 50MHz selected (needs external PU on MD18)  
0 = VESA VL bus at 50MHz not selected

[1] Select ISA Bus with PU on MD17.

| 1 = ISA bus selected (PU on MD17)  
0 = ISA bus not selected (no PU on MD17)

[0] Select 32bit PCI Bus with PU on MD16.

| 1 = 32bit PCI bus selected (PU on MD16)  
0 = 32 bit PCI bus not selected (no PU on MD16)

If [1:0] = 00 (i.e. no external PU on MD17:MD16) 32bit VESA VL bus is selected.  
No more than one PU on MD17:MD16 should be used.

Note: In AVGA3, CF14 is "Enable Local BUs Address Latching Interface". Alpine does  
not have this configuration bit. We need to do what was done in Alpine to get rid of this  
Configuration Pull-up/Pull-Down option. CAN we? WAS this done, Dwarka?

#### SR24 Panel Type Switches Register

[7] VAFCPU (VESA Advanced Feature Connector External Pull-up) Read-back.  
If external pull-up (the bit read-back 1) then all VAFC pins are configured for Video Port.  
Otherwise they have other functions or are disabled if no other function. (Disabled= the  
inputs are forced = the TTL and CMOST threshold controls are off & the outputs are tri-  
stated. It actually reads back what is latched on Reset on VAFCPU. VAFCPU is on  
MD25.

[2:0] SW2:0 pins read back (read only bits) Please note that bit [0] reads back SW0 if  
VAFCPU (SR25[2]) is 0 and ASW0PU if VAFCPU is 1. ASW0PU is on MD26.

#### Configuration Register Bits needed:

Cirrus Confidential  
Business Information

Cirrus Logic, Inc. Confidential Information

Symmetric/Asymmetric DRAM -> SR8[7] in T1, CF13 in AVGA3

=> SRF[1] 0 = Symetric DRAM Default: 0  
1 = Assymetric DRAM

This bit is read only in AVGA3 (reads back CF9), but it is writable in T1. It controls MCLK frequency as an alternate to SR1F. We will use only SR1F to program MCLK frequency in Nordic. The default MCLK frequency will be 39.374MHz, corresponding to SR1F[5:0] = 18H=22D. This frequency fully meets the spec for -80 256Kx16 DRAM-s.

Two CAS or two WE DRAM -> pin 72 in T1, CF12 in AVGA3

=> SRF[0] 0 = 2 WE DRAM (Default:0)  
1 = 2 CAS DRAM

16 or 32bit wide Video Memory (One or Two 256Kx16 DRAM-s or SDRAM-s)

-> not in T1, SRF[4:3] in AVGA3 (01=16bit, 10=32bit)  
=> SRF[7,4:3] will be used in Nordic with the same encoding as in AVGA3.  
(11 is reserved for 64bit wide). Default: 10 (32bit). See Table next page.  
Please note that we have room to add other types of DRAM-s (SDRAM-s for instance).

In AVGA3 SR8[0] is "CS OUT to EEPROM" a feature Nordic does not Support. Nordic will not change the meaning of AVGA3 bits unless they are read only (like the pins or external PU read back).

SR8[2:0] are in T1 the read-back bits for SW2:0 input pins, but AVGA3 uses them for EEPROM programming so we moved SW2:0 read back to SR24[2:0].

In T1 SR8[7] is symmetric/assymetric addressing... in Nordic this is SRF[1].

Two or one Bank 32bit wide DRAM

-> not in T1, SRF[7,4:3] in AVGA3 (00=8bit, 01=16bit, 10=32bit, 11=64bit, SRF[7] controls if 2MB of Video memory are available with 4x512Kx8 -0- or with 4 256Kx16 DRAM-s, twoi banks -1-). *It seems that in AVGA3 to support 1MB with two 256Kx16 dram-s and 32bit wide bus, we select 32bit wide and SRF[7]... but I do not exactly know how this configuration is selected.*

=> SRF[7,4:3] in Nordic, will select the Video Memory Configuration slightly differently than in AVGA3 and Alpine. See the following table.

Cirrus Confidential  
Business Information

| SRF[7]  | SRF[4] | SRF[3] | Memory Configuration            | CL 146405 |
|---------|--------|--------|---------------------------------|-----------|
| new 0   | 0      | 0      | 32bit, 2MB=4x512Kx8             |           |
| 0       | 0      | 1      | 16bit, 512KB=1x256Kx16          |           |
| 0       | 1      | 0      | 32bit, 1MB=2x256Kx16 (default)  |           |
| 0       | 1      | 1      | Reserved (64bit in Alpine)      |           |
| new ? 1 | 0      | 0      | 32bit, 2MB=4x256Kx16. Two Banks |           |
| 1       | 0      | 1      | Reserved                        |           |

|   |   |   |          |
|---|---|---|----------|
| 1 | 1 | 0 | Reserved |
| 1 | 1 | 1 | Reserved |

DRAM Timing select (short RAS or long RAS)

- > SRF[2] in T1 and AVGA3
- => SRF[2] in Nordic, default 1 = short RAS (3.5 L, 2.5H)

BIOS 48KB or 32KB -> not in T1; CF8 in AVGA3. In T1 SR8[4] is Suspend pin polarity.

In Nordic Suspend pin is always active L (0 on pin puts the chip in Suspend).

- => SR23[2] in Nordic =0 32KB BIOS (default=0) C0000:C7FFF
- =1 48KB BIOS : C0000:CCFFF

The initial BIOS code should be placed in the first 32KB starting at address C0000.

BIOS ROM ZERO\* wait select in ISA and fast timing in VL bus

- > not in T1; CF1 in AVGA3

- => SR23[1] in Nordic =0 no ZERO wait state for BIOS in ISA and slow, safe BIOS timing in VESA VL and PCI.
- =1 ZERO wait state for BIOS in ISA, 8MHz bus

Output internal VCLK on VCLK/XVCLK pin -> not in T1 or AVGA3

- => SR23[4] in Nordic =0 if SR22[7]=0, then VCLK/XVCLK is an output pin forced L
- =1 if SR22[7]=0, then VCLK/XVCLK is an output pin and it outputs VCLK.

Output internal MCLK on MCLK/XMCLK pin -> not in T1 or AVGA3.

- => SR23[0] =0 (default) force L on the pin
- =1 output mclk

Suspend/BLI bit -> not in T1 or AVGA3.

- => SR23[5] in Nordic, 0= Suspend pin in Suspend/BLI pin (default)
- 1= BLI pin on Suspend/BLI pin

Cirrus Confidential  
Business Information

SBY/ACTI bit -> not in T1 or AVGA3

- => SR23[6] in Nordic, 0= SBY on SBY/ACTI pin (default)
- 1= ACTI on SBY/ACTI pin

CL 146406

Video Port Enable bit active in PCI bus -> not in T1 or AVGA3.

(read only bit, actually reflecting the status of an external configuration PU: FCPU on MD25 latched at RESET or under S/W Control)

- => SR24[7] 0= Video Port Disable at pins to save power: inputs are forced.

outputs are L. I/O-s are inputs forced H in case they are not connected in the system.

If any shared pins, they are not in Feature Connector configuration.

1= Video Port Enabled at pins.

If any shared pins, they are now in Feature Connector Configuration.

Live Video Enable bit -> not in T1 or AVGA3.

=> SR24[6] 0= disable (default)

1= enable

Audio In (from CS4215 to Nordic) Enable bit -> not in T1 or AVGA3.

=> SR24[5] 0= disable (force inputs inactive and outputs L disable AI-FIFO and cycles)

1= enable

Audio Out (from Nordic to CS4215) Enable bit -> not in T1 or AVGA3

=> SR24[6] 0= disable (as above but AO-FIFO)

1= enable

Panel Type Switch Read-back -> SR8[2:0] in T1 or SR7[6:4], not in AVGA3

=> SR24[2:0] in Nordic, read only, writable on Reset or under S/W Control (SR24[3])

When SR24[3] whose default is 0, transits from 1 to 0 SW2:0 pin value is latched into SR24[2:0] which cannot be written by I/O.

Cross Talk Reduction Enable -> not in T1 or AVGA3.

-> SR24[3] =0 disable (default)

=1 enable - the pinout is configured to support cross talk reduction chip. The I/O registers for the cross talk reduction chip are always decoded, to make things simple. Reserve SRFX for this purpose.

Please note that R9x[1:0] TFT Panel type field of T1 was expanded to support 24bit TFT panels:

00 -> 9bit (333) (as in T1)

10 -> 12bit (444) (as in T1)

Cirrus Confidential  
Business Information

CL 146407

**Cirrus Logic, Inc. Confidential Information**

01 -> 18bit (666) [was x1 in T1 covering both 01 and 10 !!]  
11 -> 24bit (888) -> new in Nordic

**Notes:**

- a. If 24bit TFT panel is selected, all related pins will be configured for it and it has priority over panel pins configuration settings for cross talk reduction enabled.
- b. If 24bit TFT is not selected then MOD is selected on MOD/B7 pin.
- c. If STN Panels Cross Talk Reduction support is selected, and TFT type is not 24bits, then the Cross Talk Reduction support pin configuration is selected.
- d. If 24bit TFT is not selected, then SUSPST is selected on G7/SUSPST and SBYST is selected on G6/SBYST and MOD is selected on MOD/B7.

**Other Register Related Topics**

(See **nordic-reg#-rev#.lst** where # is the latest one)

**BIOS SCratch Registers #5 and #6 (2 extra required) (r/w)**

SR28:SR29[7:0] are scratch registers.

Note that SR9, SRA, SR14 and SR15 are AVGA3 scratch registers which we keep in Nordic. Also there are 13 18 bit scratch registers in the RAMDAC if SR12[1]=1.

**R9x - TFT Panel Data Format**

-----  
[7:5] Reserved

[4:2] Select a 0 to 7 shift-clock delay from the internal character clock counter  
(8 VCLK/Character Clock) to TFT panel HSYNC (LLCLK) signal -> as in T1.

[1:0] TFT Panel Type:

00 -> 9bit (333) (as in T1)

10 -> 12bit (444) (as in T1)

01 -> 18bit (666) [was x1 in T1 covering both 01 and 10 !!]

11 -> 24bit (888) -> new in Nordic

**Registers that are Moved Relative to T1**

**Cirrus Confidential  
Business Information**

**CL 146408**

**Cirrus Logic, Inc. Confidential Information**

**CR1B[7,4,3,2] (R1B in schematics):**

- [7] Disable Text Cursor Blink in T1. Do we use this feature in T1?  
Enable Blank End Extensions in AVGA3
- [4] PCLKO (Panel Clock) no divide by two control in T1.  
I am not sure this bit is actually needed in Nordic.
- [3] IRQ Every Frame or Every Other Frame ? Is this bit used in T1?
- [2] Not Used at All in T1.

I think that all these bits are not actually used. Are they needed ? -> Robin.

**CR1C[7:0] & CR1D[7:0]**

Are important LCD and Power Management Registers in T1 and Overlay Registers in Alpine. These registers are not in AVGA3, but because they are used in Alpine we may move them to CR2C[7:0] and CR2D[7:0], which requires one more CRTC Index Register Bit. So:

CR1C -> CR2C & CR1D -> CR2D in Nordic relative to T1.

**SRF[7]**

In T1 is CRT Refresh Disable. This bit gates /FB/RWC[5] in FB sheet 6. In AVGA3 is DRAM Two Bank Configuration select bit.  
I don't think that this bit is used in T1 ? -> Robin.

**SR16**

In T1 is used to control the pads for power and threshold. In AVGA3 is not used. In Alpine is CRT FIFO demand threshold and other things ([4:0] are used).

Move SR16 bits of T1 to SR20 to avoid contention with Alpine. Increase SRX Sequencer Register Index to 6 bits.

**SR1A**

In T1 is used as Test register. In AVGA3 and Alpine is Signature Generator Result Hi.  
Move T1 SR1A bits to SR21 if it is not replaced by a similar register in AVGA3.

**Nordic Revision and Mask Codes**

Nordic Revision: ??  
Nordic Mask Code: 00

**Cirrus Confidential  
Business Information**

-----SSSS-----

**CL 146409**

**This Page is Inserted by IFW Indexing and Scanning  
Operations and is not part of the Official Record**

## **BEST AVAILABLE IMAGES**

Defective images within this document are accurate representations of the original documents submitted by the applicant.

Defects in the images include but are not limited to the items checked:

- BLACK BORDERS**
- IMAGE CUT OFF AT TOP, BOTTOM OR SIDES**
- FADED TEXT OR DRAWING**
- BLURRED OR ILLEGIBLE TEXT OR DRAWING**
- SKEWED/SLANTED IMAGES**
- COLOR OR BLACK AND WHITE PHOTOGRAPHS**
- GRAY SCALE DOCUMENTS**
- LINES OR MARKS ON ORIGINAL DOCUMENT**
- REFERENCE(S) OR EXHIBIT(S) SUBMITTED ARE POOR QUALITY**
- OTHER:** \_\_\_\_\_

**IMAGES ARE BEST AVAILABLE COPY.**

**As rescanning these documents will not correct the image problems checked, please do not report these problems to the IFW Image Problem Mailbox.**